/*********************************************************************
 * Copyright (C) 2002 Andrew Khan
 * <p>
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 * <p>
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 * <p>
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
 ***************************************************************************/

package jxl.write.biff;

import jxl.biff.Fonts;
import jxl.biff.FormattingRecords;
import jxl.biff.NumFormatRecordsException;
import jxl.common.Assert;
import jxl.write.NumberFormats;
import jxl.write.WritableCellFormat;


/**
 * Handles the Format and XF record indexing.  The writable subclass
 * instantiates the predetermined list of XF records and formats
 * present in every Excel Workbook
 */
public class WritableFormattingRecords extends FormattingRecords {
    /**
     * The statically defined normal style
     */
    public static WritableCellFormat normalStyle;

    /**
     * Constructor.  Instantiates the prerequisite list of formats and
     * styles required by all Excel workbooks
     *
     * @param f the list of Fonts
     * @param styles the list of style clones
     */
    public WritableFormattingRecords(Fonts f, Styles styles) {
        super(f);

        try {
            // Hard code all the styles
            StyleXFRecord sxf = new StyleXFRecord
                    (styles.getArial10Pt(), NumberFormats.DEFAULT);
            sxf.setLocked(true);
            addStyle(sxf);

            sxf = new StyleXFRecord(getFonts().getFont(1), NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(getFonts().getFont(1), NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(getFonts().getFont(1), NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(getFonts().getFont(2), NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(getFonts().getFont(3), NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(styles.getArial10Pt(),
                    NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(styles.getArial10Pt(),
                    NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(styles.getArial10Pt(),
                    NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(styles.getArial10Pt(),
                    NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(styles.getArial10Pt(),
                    NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(styles.getArial10Pt(),
                    NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(styles.getArial10Pt(),
                    NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(styles.getArial10Pt(),
                    NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            sxf = new StyleXFRecord(styles.getArial10Pt(),
                    NumberFormats.DEFAULT);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf400);
            addStyle(sxf);

            // That's the end of the built ins.  Write the normal style
            // cell XF here
            addStyle(styles.getNormalStyle());

            // Continue with "user defined" styles
            sxf = new StyleXFRecord(getFonts().getFont(1),
                    NumberFormats.FORMAT7);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf800);
            addStyle(sxf);

            sxf = new StyleXFRecord(getFonts().getFont(1),
                    NumberFormats.FORMAT5);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf800);
            addStyle(sxf);

            sxf = new StyleXFRecord(getFonts().getFont(1),
                    NumberFormats.FORMAT8);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf800);
            addStyle(sxf);

            sxf = new StyleXFRecord(getFonts().getFont(1),
                    NumberFormats.FORMAT6);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf800);
            addStyle(sxf);

            sxf = new StyleXFRecord(getFonts().getFont(1),
                    NumberFormats.PERCENT_INTEGER);
            sxf.setLocked(true);
            sxf.setCellOptions(0xf800);
            addStyle(sxf);

            // Hard code in the pre-defined number formats for now
      /*
        FormatRecord fr = new FormatRecord
        ("\"$\"#,##0_);\\(\"$\"#,##0\\)",5);
        addFormat(fr);

        fr = new FormatRecord
        ("\"$\"#,##0_);[Red]\\(\"$\"#,##0\\)", 6);
        addFormat(fr);

        fr = new FormatRecord
        ("\"$\"#,##0.00_);\\(\"$\"#,##0.00\\)", 7);
        addFormat(fr);

        fr = new FormatRecord
        ("\"$\"#,##0.00_);[Red]\\(\"$\"#,##0.00\\)", 8);
        addFormat(fr);

        fr = new FormatRecord
        ("_(\"$\"* #,##0_);_(\"$\"* \\(#,##0\\);_(\"$\"* \"-\"_);_(@_)",
        0x2a);
        //        outputFile.write(fr);

        fr = new FormatRecord
        ("_(* #,##0_);_(* \\(#,##0\\);_(* \"-\"_);_(@_)",
        0x2e);
        //        outputFile.write(fr);

        fr = new FormatRecord
        ("_(\"$\"* #,##0.00_);_(\"$\"* \\(#,##0.00\\);_(\"$\"* \"-\"??_);_(@_)",
        0x2c);
        //        outputFile.write(fr);

        fr = new FormatRecord
        ("_(* #,##0.00_);_(* \\(#,##0.00\\);_(* \"-\"??_);_(@_)",
        0x2b);
        //        outputFile.write(fr);
        */
        } catch (NumFormatRecordsException e) {
            // This should not happen yet, since we are just creating the file.
            // Bomb out
            Assert.verify(false, e.getMessage());
        }
    }
}









